<!DOCTYPE html>
<html lang=zh>
<head>
    <!-- so meta -->
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="HandheldFriendly" content="True">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=5" />
    <meta name="description" content="通过包管理工具我们可以更好的管理自己的工具包，其他人也可以更好的使用我们的工具包。 npm包管理工具Node Package Manager，也就是Node包管理器，但是目前已经不仅仅是Node包管理器了，在前端项目中我们也在使用它来管理依赖的包，比如express、koa、react、react-dom、axios、babel、webpack等等 npm管理的包存放在哪里呢：  我们发布自己的包">
<meta property="og:type" content="article">
<meta property="og:title" content="包管理工具">
<meta property="og:url" content="https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/index.html">
<meta property="og:site_name" content="柯里的语法糖">
<meta property="og:description" content="通过包管理工具我们可以更好的管理自己的工具包，其他人也可以更好的使用我们的工具包。 npm包管理工具Node Package Manager，也就是Node包管理器，但是目前已经不仅仅是Node包管理器了，在前端项目中我们也在使用它来管理依赖的包，比如express、koa、react、react-dom、axios、babel、webpack等等 npm管理的包存放在哪里呢：  我们发布自己的包">
<meta property="og:locale" content="zh_CN">
<meta property="og:image" content="https://codertzm.oss-cn-chengdu.aliyuncs.com/image-20220312201625182.png">
<meta property="article:published_time" content="2022-03-11T16:00:00.000Z">
<meta property="article:modified_time" content="2022-03-19T02:34:36.954Z">
<meta property="article:author" content="柯里的语法糖">
<meta property="article:tag" content="npm">
<meta name="twitter:card" content="summary">
<meta name="twitter:image" content="https://codertzm.oss-cn-chengdu.aliyuncs.com/image-20220312201625182.png">
    
    
      
        
          <link rel="shortcut icon" href="https://codertzm.oss-cn-chengdu.aliyuncs.com/favicon.ico">
        
      
      
        
          <link rel="icon" type="image/png" href="https://codertzm.oss-cn-chengdu.aliyuncs.com/favicon.ico" sizes="192x192">
        
      
      
        
          <link rel="apple-touch-icon" sizes="180x180" href="https://codertzm.oss-cn-chengdu.aliyuncs.com/favicon.ico">
        
      
    
    <!-- title -->
    <title>包管理工具</title>
    <!-- styles -->
    
<link rel="stylesheet" href="/css/style.css">

    <!-- persian styles -->
    
    <!-- rss -->
    
    
	<!-- mathjax -->
	
<meta name="generator" content="Hexo 6.0.0"></head>

<body class="max-width mx-auto px3 ltr">
    
      <div id="header-post">
  <a id="menu-icon" href="#" aria-label="Menu"><i class="fas fa-bars fa-lg"></i></a>
  <a id="menu-icon-tablet" href="#" aria-label="Menu"><i class="fas fa-bars fa-lg"></i></a>
  <a id="top-icon-tablet" href="#" aria-label="Top" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');" style="display:none;"><i class="fas fa-chevron-up fa-lg"></i></a>
  <span id="menu">
    <span id="nav">
      <ul>
        <!--
       --><li><a href="/">首页</a></li><!--
     --><!--
       --><li><a href="/tags/">标签</a></li><!--
     --><!--
       --><li><a href="/categories/">分类</a></li><!--
     --><!--
       --><li><a href="/archives/">归档</a></li><!--
     --><!--
       --><li><a target="_blank" rel="noopener" href="http://github.com/twitzz">项目</a></li><!--
     --><!--
       --><li><a href="/about/">关于</a></li><!--
     --><!--
       --><li><a href="/search/">搜索</a></li><!--
     -->
      </ul>
    </span>
    <br/>
    <span id="actions">
      <ul>
        
        <li><a class="icon" aria-label="上一篇" href="/2022/03/16/frontend/%E5%89%8D%E7%AB%AF%E9%9D%A2%E8%AF%95%E5%A4%8D%E4%B9%A0/"><i class="fas fa-chevron-left" aria-hidden="true" onmouseover="$('#i-prev').toggle();" onmouseout="$('#i-prev').toggle();"></i></a></li>
        
        
        <li><a class="icon" aria-label="下一篇" href="/2022/03/11/nodejs/%E6%A8%A1%E5%9D%97%E5%8C%96/"><i class="fas fa-chevron-right" aria-hidden="true" onmouseover="$('#i-next').toggle();" onmouseout="$('#i-next').toggle();"></i></a></li>
        
        <li><a class="icon" aria-label="返回顶部" href="#" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');"><i class="fas fa-chevron-up" aria-hidden="true" onmouseover="$('#i-top').toggle();" onmouseout="$('#i-top').toggle();"></i></a></li>
        <li><a class="icon" aria-label="分享文章" href="#"><i class="fas fa-share-alt" aria-hidden="true" onmouseover="$('#i-share').toggle();" onmouseout="$('#i-share').toggle();" onclick="$('#share').toggle();return false;"></i></a></li>
      </ul>
      <span id="i-prev" class="info" style="display:none;">上一篇</span>
      <span id="i-next" class="info" style="display:none;">下一篇</span>
      <span id="i-top" class="info" style="display:none;">返回顶部</span>
      <span id="i-share" class="info" style="display:none;">分享文章</span>
    </span>
    <br/>
    <div id="share" style="display: none">
      <ul>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.facebook.com/sharer.php?u=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/"><i class="fab fa-facebook " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://twitter.com/share?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&text=包管理工具"><i class="fab fa-twitter " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.linkedin.com/shareArticle?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-linkedin " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://pinterest.com/pin/create/bookmarklet/?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&is_video=false&description=包管理工具"><i class="fab fa-pinterest " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="mailto:?subject=包管理工具&body=Check out this article: https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/"><i class="fas fa-envelope " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://getpocket.com/save?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-get-pocket " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://reddit.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-reddit " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.stumbleupon.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-stumbleupon " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://digg.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-digg " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.tumblr.com/share/link?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&name=包管理工具&description="><i class="fab fa-tumblr " aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://news.ycombinator.com/submitlink?u=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&t=包管理工具"><i class="fab fa-hacker-news " aria-hidden="true"></i></a></li>
</ul>

    </div>
    <div id="toc">
      <ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#npm%E5%8C%85%E7%AE%A1%E7%90%86%E5%B7%A5%E5%85%B7"><span class="toc-number">1.</span> <span class="toc-text">npm包管理工具</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E9%A1%B9%E7%9B%AE%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6"><span class="toc-number">1.1.</span> <span class="toc-text">项目配置文件</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%89%88%E6%9C%AC%E7%AE%A1%E7%90%86%E9%97%AE%E9%A2%98"><span class="toc-number">1.2.</span> <span class="toc-text">版本管理问题</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#npm-install"><span class="toc-number">1.3.</span> <span class="toc-text">npm install</span></a><ol class="toc-child"><li class="toc-item toc-level-4"><a class="toc-link" href="#%E5%85%A8%E5%B1%80%E5%AE%89%E8%A3%85"><span class="toc-number">1.3.1.</span> <span class="toc-text">全局安装</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#%E9%A1%B9%E7%9B%AE%E5%AE%89%E8%A3%85"><span class="toc-number">1.3.2.</span> <span class="toc-text">项目安装</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#npm-install-%E5%8E%9F%E7%90%86"><span class="toc-number">1.3.3.</span> <span class="toc-text">npm install 原理</span></a></li></ol></li><li class="toc-item toc-level-3"><a class="toc-link" href="#package-lock-json"><span class="toc-number">1.4.</span> <span class="toc-text">package-lock.json</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#npm%E5%85%B6%E4%BB%96%E5%91%BD%E4%BB%A4"><span class="toc-number">1.5.</span> <span class="toc-text">npm其他命令</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Yarn%E5%B7%A5%E5%85%B7"><span class="toc-number">2.</span> <span class="toc-text">Yarn工具</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#npx%E5%B7%A5%E5%85%B7"><span class="toc-number">3.</span> <span class="toc-text">npx工具</span></a></li></ol>
    </div>
  </span>
</div>

    
    <div class="content index py4">
        
        <article class="post" itemscope itemtype="http://schema.org/BlogPosting">
  <header>
    
    <h1 class="posttitle" itemprop="name headline">
        包管理工具
    </h1>



    <div class="meta">
      <span class="author" itemprop="author" itemscope itemtype="http://schema.org/Person">
        <span itemprop="name">柯里的语法糖</span>
      </span>
      
    <div class="postdate">
      
        <time datetime="2022-03-11T16:00:00.000Z" itemprop="datePublished">2022-03-12</time>
        
      
    </div>


      
    <div class="article-category">
        <i class="fas fa-archive"></i>
        <a class="category-link" href="/categories/nodejs/">nodejs</a>
    </div>


      
    <div class="article-tag">
        <i class="fas fa-tag"></i>
        <a class="tag-link-link" href="/tags/npm/" rel="tag">npm</a>
    </div>


    </div>
  </header>
  

  <div class="content" itemprop="articleBody">
    <p>通过包管理工具我们可以更好的管理自己的工具包，其他人也可以更好的使用我们的工具包。</p>
<h2 id="npm包管理工具"><a href="#npm包管理工具" class="headerlink" title="npm包管理工具"></a>npm包管理工具</h2><p>Node Package Manager，也就是Node包管理器，但是目前已经不仅仅是Node包管理器了，在前端项目中我们也在使用它来管理依赖的包，比如express、koa、react、react-dom、axios、babel、webpack等等</p>
<p>npm管理的包存放在哪里呢：</p>
<ul>
<li>我们发布自己的包其实是发布到<strong>registry</strong>上面的</li>
<li> 当我们安装一个包时其实是从<strong>registry</strong>上面下载的包</li>
</ul>
<h3 id="项目配置文件"><a href="#项目配置文件" class="headerlink" title="项目配置文件"></a>项目配置文件</h3><p>常见属性：</p>
<ul>
<li>必填属性：name、version<ul>
<li>name是项目名称</li>
<li>version是当前项目的版本号</li>
<li>description是项目描述</li>
<li>author是作者相关信息（发布时用到）</li>
<li>license是开源协议（发布时用到）</li>
</ul>
</li>
<li>private属性：<ul>
<li>记录当前的项目是否是私有的</li>
<li>当值为true时，npm是不能发布它的，这是防止私有项目或模块发布出去的方式</li>
</ul>
</li>
<li>main属性：<ul>
<li>设置程序的主入口</li>
<li>这个入口和webpack打包的入口并不冲突，它是在你发布一个模块的时候会用到的</li>
</ul>
</li>
<li>scripts属性：<ul>
<li>用于配置一些脚本命令，以键值对的形式存在</li>
<li>配置后我们可以通过 npm run 命令的key来执行这个命令</li>
<li>npm start和npm run start的区别是什么：<ul>
<li>它们是等价的</li>
<li>对于常用的 start、 test、stop、restart可以省略掉run直接通过 npm start等方式运行</li>
</ul>
</li>
</ul>
</li>
<li>dependencies属性：<ul>
<li>dependencies属性是指定无论开发环境还是生成环境都需要依赖的包</li>
<li>通常是我们项目实际开发用到的一些库模块</li>
</ul>
</li>
<li>devDependencies属性<ul>
<li>一些包在生成环境是不需要的，比如webpack、babel等</li>
<li>这个时候我们会通过 npm install webpack –save-dev，将它安装到devDependencies属性中</li>
</ul>
</li>
<li>engines属性：<ul>
<li>engines属性用于指定Node和NPM的版本号</li>
<li>在安装的过程中，会先检查对应的引擎版本，如果不符合就会报错</li>
<li>也可以指定所在的操作系统 “os” : [ “darwin”, “linux” ]，只是很少用到</li>
</ul>
</li>
<li>browserslist属性：<ul>
<li>用于配置打包后的JavaScript浏览器的兼容情况，否则我们需要手动的添加polyfills来让支持某些语法</li>
<li>也就是说它是为webpack等打包工具服务的一个属性</li>
</ul>
</li>
</ul>
<h3 id="版本管理问题"><a href="#版本管理问题" class="headerlink" title="版本管理问题"></a>版本管理问题</h3><p>npm的包通常需要遵从semver版本规范：</p>
<ul>
<li>semver：<a target="_blank" rel="noopener" href="https://semver.org/lang/zh-CN/">https://semver.org/lang/zh-CN/</a></li>
<li>npm semver：<a target="_blank" rel="noopener" href="https://docs.npmjs.com/misc/semver">https://docs.npmjs.com/misc/semver</a></li>
</ul>
<p>semver版本规范是X.Y.Z：</p>
<ul>
<li><p>X主版本号（major）：当你做了不兼容的 API 修改（可能不兼容之前的版本）</p>
</li>
<li><p>Y次版本号（minor）：当你做了向下兼容的功能性新增（新功能增加，但是兼容之前的版本）</p>
</li>
<li><p>Z修订号（patch）：当你做了向下兼容的问题修正（没有新功能，修复了之前版本的bug）</p>
</li>
<li><p><em>^和~的区别：</em>*</p>
</li>
<li><p>^x.y.z：表示x是保持不变的，y和z永远安装最新的版本</p>
</li>
<li><p>~x.y.z：表示x和y保持不变的，z永远安装最新的版本</p>
</li>
</ul>
<h3 id="npm-install"><a href="#npm-install" class="headerlink" title="npm install"></a>npm install</h3><p>安装npm包分两种情况：</p>
<ul>
<li>全局安装（global install）： npm install yarn -g</li>
<li>项目（局部）安装（local install）： npm install</li>
</ul>
<h4 id="全局安装"><a href="#全局安装" class="headerlink" title="全局安装"></a>全局安装</h4><p>全局安装是直接将某个包安装到全局，通常使用npm全局安装的包都是一些工具包：yarn、webpack，并不是类似于 axios、express、koa等库文件，所以全局安装了之后并不能让我们在所有的项目中使用 axios等库。</p>
<h4 id="项目安装"><a href="#项目安装" class="headerlink" title="项目安装"></a>项目安装</h4><p>项目安装会在当前目录下生产一个 node_modules 文件夹</p>
<p> 局部安装分为开发时依赖和生产时依赖：</p>
<p>安装开发时依赖：</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td><td class="code"><pre><span class="line">npm install webpack --save-dev</span><br><span class="line">npm install webpack -D</span><br><span class="line">npm i webpack -D</span><br></pre></td></tr></table></figure>

<p>安装生产时依赖：</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br></pre></td><td class="code"><pre><span class="line">npm install axios</span><br><span class="line">npm i axios</span><br></pre></td></tr></table></figure>

<p>根据package.json中的依赖包</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">npm install</span><br></pre></td></tr></table></figure>

<h4 id="npm-install-原理"><a href="#npm-install-原理" class="headerlink" title="npm install 原理"></a>npm install 原理</h4><p>原理图：</p>
<p><img src="https://codertzm.oss-cn-chengdu.aliyuncs.com/image-20220312201625182.png" alt="image-20220312201625182"></p>
<p>npm install会检测是否有package-lock.json文件：</p>
<ul>
<li>没有lock文件:<ul>
<li>分析依赖关系，这是因为我们可能包会依赖其他的包，并且多个包之间会产生相同依赖的情况</li>
<li>从registry仓库中下载压缩包（如果我们设置了镜像，那么会从镜像服务器下载压缩包）</li>
<li> 获取到压缩包后会对压缩包进行缓存（从npm5开始有的） </li>
<li>将压缩包解压到项目的node_modules文件夹中</li>
</ul>
</li>
<li>有lock文件:<ul>
<li>检测lock中包的版本是否和package.json中一致（会按照semver版本规范检测）<ul>
<li>不一致，那么会重新构建依赖关系，直接会走顶层的流程</li>
</ul>
</li>
<li>一致的情况下，会去优先查找缓存<ul>
<li>没有找到，会从registry仓库下载，直接走顶层流程</li>
</ul>
</li>
<li>查找到，会获取缓存中的压缩文件，并且将压缩文件解压到node_modules文件夹中</li>
</ul>
</li>
</ul>
<h3 id="package-lock-json"><a href="#package-lock-json" class="headerlink" title="package-lock.json"></a>package-lock.json</h3><p>属性：</p>
<ul>
<li>name：项目的名称</li>
<li>version：项目的版本</li>
<li>lockfileVersion：lock文件的版本</li>
<li>requires：使用requires来跟着模块的依赖关系</li>
<li>dependencies：项目的依赖<ul>
<li>version表示实际安装依赖的版本</li>
<li>resolved用来记录下载的地址，registry仓库 中的位置</li>
<li>requires记录当前模块的依赖</li>
<li>integrity用来从缓存中获取索引，再通过索引 去获取压缩包文件</li>
</ul>
</li>
</ul>
<h3 id="npm其他命令"><a href="#npm其他命令" class="headerlink" title="npm其他命令"></a>npm其他命令</h3><p>卸载某个依赖包：</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td><td class="code"><pre><span class="line">npm uninstall package</span><br><span class="line">npm uninstall package --save-dev</span><br><span class="line">npm uninstall package -D</span><br></pre></td></tr></table></figure>

<p>强制重新build：</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">npm rebuild</span><br></pre></td></tr></table></figure>

<p> 清除缓存：</p>
<figure class="highlight shell"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">npm cache clean</span><br></pre></td></tr></table></figure>

<h2 id="Yarn工具"><a href="#Yarn工具" class="headerlink" title="Yarn工具"></a>Yarn工具</h2><p>yarn是由Facebook、Google、Exponent 和 Tilde 联合推出了一个新的 JS 包管理工具，是为了弥补 npm 的一些缺陷而出现的</p>
<p>早期的npm存在很多的缺陷，比如安装依赖速度很慢、版本依赖混乱等等一系列的问题</p>
<p>虽然从npm5版本开始，进行了很多的升级和改进，但是依然很多人喜欢使用yarn</p>
<h2 id="npx工具"><a href="#npx工具" class="headerlink" title="npx工具"></a>npx工具</h2><p>npx是npm5.2之后自带的一个命令。</p>
<p>npx的作用非常多，但是比较常见的是使用它来调用项目中的某个模块的指令</p>

  </div>
</article>



        
          <div id="footer-post-container">
  <div id="footer-post">

    <div id="nav-footer" style="display: none">
      <ul>
         
          <li><a href="/">首页</a></li>
         
          <li><a href="/tags/">标签</a></li>
         
          <li><a href="/categories/">分类</a></li>
         
          <li><a href="/archives/">归档</a></li>
         
          <li><a target="_blank" rel="noopener" href="http://github.com/twitzz">项目</a></li>
         
          <li><a href="/about/">关于</a></li>
         
          <li><a href="/search/">搜索</a></li>
        
      </ul>
    </div>

    <div id="toc-footer" style="display: none">
      <ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#npm%E5%8C%85%E7%AE%A1%E7%90%86%E5%B7%A5%E5%85%B7"><span class="toc-number">1.</span> <span class="toc-text">npm包管理工具</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E9%A1%B9%E7%9B%AE%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6"><span class="toc-number">1.1.</span> <span class="toc-text">项目配置文件</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%89%88%E6%9C%AC%E7%AE%A1%E7%90%86%E9%97%AE%E9%A2%98"><span class="toc-number">1.2.</span> <span class="toc-text">版本管理问题</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#npm-install"><span class="toc-number">1.3.</span> <span class="toc-text">npm install</span></a><ol class="toc-child"><li class="toc-item toc-level-4"><a class="toc-link" href="#%E5%85%A8%E5%B1%80%E5%AE%89%E8%A3%85"><span class="toc-number">1.3.1.</span> <span class="toc-text">全局安装</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#%E9%A1%B9%E7%9B%AE%E5%AE%89%E8%A3%85"><span class="toc-number">1.3.2.</span> <span class="toc-text">项目安装</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#npm-install-%E5%8E%9F%E7%90%86"><span class="toc-number">1.3.3.</span> <span class="toc-text">npm install 原理</span></a></li></ol></li><li class="toc-item toc-level-3"><a class="toc-link" href="#package-lock-json"><span class="toc-number">1.4.</span> <span class="toc-text">package-lock.json</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#npm%E5%85%B6%E4%BB%96%E5%91%BD%E4%BB%A4"><span class="toc-number">1.5.</span> <span class="toc-text">npm其他命令</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Yarn%E5%B7%A5%E5%85%B7"><span class="toc-number">2.</span> <span class="toc-text">Yarn工具</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#npx%E5%B7%A5%E5%85%B7"><span class="toc-number">3.</span> <span class="toc-text">npx工具</span></a></li></ol>
    </div>

    <div id="share-footer" style="display: none">
      <ul>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.facebook.com/sharer.php?u=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/"><i class="fab fa-facebook fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://twitter.com/share?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&text=包管理工具"><i class="fab fa-twitter fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.linkedin.com/shareArticle?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-linkedin fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://pinterest.com/pin/create/bookmarklet/?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&is_video=false&description=包管理工具"><i class="fab fa-pinterest fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="mailto:?subject=包管理工具&body=Check out this article: https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/"><i class="fas fa-envelope fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://getpocket.com/save?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-get-pocket fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://reddit.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-reddit fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.stumbleupon.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-stumbleupon fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://digg.com/submit?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&title=包管理工具"><i class="fab fa-digg fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="http://www.tumblr.com/share/link?url=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&name=包管理工具&description="><i class="fab fa-tumblr fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" target="_blank" rel="noopener" href="https://news.ycombinator.com/submitlink?u=https://danyuan30.gitee.io/2022/03/12/nodejs/npm%E5%8C%85%E7%AE%A1%E7%90%86/&t=包管理工具"><i class="fab fa-hacker-news fa-lg" aria-hidden="true"></i></a></li>
</ul>

    </div>

    <div id="actions-footer">
        <a id="menu" class="icon" href="#" onclick="$('#nav-footer').toggle();return false;"><i class="fas fa-bars fa-lg" aria-hidden="true"></i> 菜单</a>
        <a id="toc" class="icon" href="#" onclick="$('#toc-footer').toggle();return false;"><i class="fas fa-list fa-lg" aria-hidden="true"></i> 目录</a>
        <a id="share" class="icon" href="#" onclick="$('#share-footer').toggle();return false;"><i class="fas fa-share-alt fa-lg" aria-hidden="true"></i> 分享</a>
        <a id="top" style="display:none" class="icon" href="#" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');"><i class="fas fa-chevron-up fa-lg" aria-hidden="true"></i> 返回顶部</a>
    </div>

  </div>
</div>

        
        <footer id="footer">
  <div class="footer-left">
    Copyright &copy;
    
    
    2021-2022
    柯里的语法糖
  </div>
  <div class="footer-right">
    <nav>
      <ul>
        <!--
       --><li><a href="/">首页</a></li><!--
     --><!--
       --><li><a href="/tags/">标签</a></li><!--
     --><!--
       --><li><a href="/categories/">分类</a></li><!--
     --><!--
       --><li><a href="/archives/">归档</a></li><!--
     --><!--
       --><li><a target="_blank" rel="noopener" href="http://github.com/twitzz">项目</a></li><!--
     --><!--
       --><li><a href="/about/">关于</a></li><!--
     --><!--
       --><li><a href="/search/">搜索</a></li><!--
     -->
      </ul>
    </nav>
  </div>
</footer>

    </div>
    <!-- styles -->



  <link rel="preload" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.2/css/all.min.css" crossorigin="anonymous" onload="this.onload=null;this.rel='stylesheet'"/>


    <!-- jquery -->
 
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js" crossorigin="anonymous"></script> 




<!-- clipboard -->

  
    <script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.7/clipboard.min.js" crossorigin="anonymous"></script> 
  
  <script type="text/javascript">
  $(function() {
    // copy-btn HTML
    var btn = "<span class=\"btn-copy tooltipped tooltipped-sw\" aria-label=\"复制到粘贴板!\">";
    btn += '<i class="far fa-clone"></i>';
    btn += '</span>'; 
    // mount it!
    $(".highlight table").before(btn);
    var clip = new ClipboardJS('.btn-copy', {
      text: function(trigger) {
        return Array.from(trigger.nextElementSibling.querySelectorAll('.code')).reduce((str,it)=>str+it.innerText+'\n','')
      }
    });
    clip.on('success', function(e) {
      e.trigger.setAttribute('aria-label', "复制成功!");
      e.clearSelection();
    })
  })
  </script>


<script src="/js/main.js"></script>

<!-- search -->

<!-- Google Analytics -->

<!-- Baidu Analytics -->

<!-- Cloudflare Analytics -->

<!-- Umami Analytics -->

<!-- Disqus Comments -->

<!-- utterances Comments -->

</body>
</html>
